home *** CD-ROM | disk | FTP | other *** search
/ Chip 2007 January, February, March & April / Chip-Cover-CD-2007-02.iso / Pakiet bezpieczenstwa / mini Pentoo LiveCD 2006.1 / mpentoo-2006.1.iso / livecd.squashfs / usr / include / alsa / seqmid.h < prev    next >
C/C++ Source or Header  |  2006-01-09  |  14KB  |  491 lines

  1. /**
  2.  * \file include/seqmid.h
  3.  * \brief Application interface library for the ALSA driver
  4.  * \author Jaroslav Kysela <perex@suse.cz>
  5.  * \author Abramo Bagnara <abramo@alsa-project.org>
  6.  * \author Takashi Iwai <tiwai@suse.de>
  7.  * \date 1998-2001
  8.  *
  9.  * Application interface library for the ALSA driver
  10.  */
  11. /*
  12.  *   This library is free software; you can redistribute it and/or modify
  13.  *   it under the terms of the GNU Lesser General Public License as
  14.  *   published by the Free Software Foundation; either version 2.1 of
  15.  *   the License, or (at your option) any later version.
  16.  *
  17.  *   This program is distributed in the hope that it will be useful,
  18.  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
  19.  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  20.  *   GNU Lesser General Public License for more details.
  21.  *
  22.  *   You should have received a copy of the GNU Lesser General Public
  23.  *   License along with this library; if not, write to the Free Software
  24.  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
  25.  *
  26.  */
  27.  
  28. #ifndef __ALSA_SEQMID_H
  29. #define __ALSA_SEQMID_H
  30.  
  31. #ifdef __cplusplus
  32. extern "C" {
  33. #endif
  34.  
  35. /**
  36.  *  \defgroup SeqMiddle Sequencer Middle Level Interface
  37.  *  Sequencer Middle Level Interface
  38.  *  \ingroup Sequencer
  39.  *  \{
  40.  */
  41.  
  42. /**
  43.  * \brief initialize event record
  44.  * \param ev event record pointer
  45.  * 
  46.  * This macro clears the given event record pointer to the default status.
  47.  */
  48. #define snd_seq_ev_clear(ev) \
  49.     memset(ev, 0, sizeof(snd_seq_event_t))
  50.  
  51. /**
  52.  * \brief set the tag for given event
  53.  * \param ev event record
  54.  * \param t event tag
  55.  *
  56.  * This macro sets the tag to the given event record.
  57.  */
  58. #define snd_seq_ev_set_tag(ev,t) \
  59.     ((ev)->tag = (t))
  60.  
  61. /**
  62.  * \brief set the explicit destination
  63.  * \param ev event record
  64.  * \param c destination client id
  65.  * \param p destination port id
  66.  *
  67.  * This macro sets the client and port id numbers to the given event record.
  68.  *
  69.  * \sa snd_seq_ev_set_subs()
  70.  */
  71. #define snd_seq_ev_set_dest(ev,c,p) \
  72.     ((ev)->dest.client = (c), (ev)->dest.port = (p))
  73.  
  74. /**
  75.  * \brief set broadcasting to subscribers
  76.  * \param ev event record
  77.  *
  78.  * This macro sets the destination as the subscribers.
  79.  *
  80.  * \sa snd_seq_ev_set_dest()
  81.  */
  82. #define snd_seq_ev_set_subs(ev) \
  83.     ((ev)->dest.client = SND_SEQ_ADDRESS_SUBSCRIBERS,\
  84.      (ev)->dest.port = SND_SEQ_ADDRESS_UNKNOWN)
  85.  
  86. /**
  87.  * \brief set broadcasting to all clients/ports
  88.  * \param ev event record
  89.  *
  90.  * This macro sets the destination as the broadcasting.
  91.  *
  92.  * \sa snd_seq_ev_set_dest()
  93.  */
  94. #define snd_seq_ev_set_broadcast(ev) \
  95.     ((ev)->dest.client = SND_SEQ_ADDRESS_BROADCAST,\
  96.      (ev)->dest.port = SND_SEQ_ADDRESS_BROADCAST)
  97.  
  98. /**
  99.  * \brief set the source port
  100.  * \param ev event record
  101.  * \param p source port id
  102.  *
  103.  * This macro sets the source port id number.
  104.  */
  105. #define snd_seq_ev_set_source(ev,p) \
  106.     ((ev)->source.port = (p))
  107.  
  108. /**
  109.  * \brief set direct passing mode (without queued)
  110.  * \param ev event instance
  111.  *
  112.  * This macro sets the event to the direct passing mode
  113.  * to be delivered immediately without queueing.
  114.  * 
  115.  * \sa snd_seq_ev_schedule_tick(), snd_seq_ev_schedule_real()
  116.  */
  117. #define snd_seq_ev_set_direct(ev) \
  118.     ((ev)->queue = SND_SEQ_QUEUE_DIRECT)
  119.  
  120. /**
  121.  * \brief set tick-scheduling mode on queue
  122.  * \param ev event instance
  123.  * \param q queue id to schedule
  124.  * \param relative relative time-stamp if non-zero
  125.  * \param ttick tick time-stamp to be delivered
  126.  *
  127.  * This macro sets the scheduling of the event in the
  128.  * MIDI tick mode.
  129.  *
  130.  * \sa snd_seq_ev_schedule_real(), snd_seq_ev_set_direct()
  131.  */
  132. #define snd_seq_ev_schedule_tick(ev, q, relative, ttick) \
  133.     ((ev)->flags &= ~(SND_SEQ_TIME_STAMP_MASK | SND_SEQ_TIME_MODE_MASK),\
  134.      (ev)->flags |= SND_SEQ_TIME_STAMP_TICK,\
  135.      (ev)->flags |= (relative) ? SND_SEQ_TIME_MODE_REL : SND_SEQ_TIME_MODE_ABS,\
  136.      (ev)->time.tick = (ttick),\
  137.      (ev)->queue = (q))
  138.  
  139. /**
  140.  * \brief set real-time-scheduling mode on queue
  141.  * \param ev event instance
  142.  * \param q queue id to schedule
  143.  * \param relative relative time-stamp if non-zero
  144.  * \param rtime time-stamp to be delivered
  145.  *
  146.  * This macro sets the scheduling of the event in the
  147.  * realtime mode.
  148.  *
  149.  * \sa snd_seq_ev_schedule_tick(), snd_seq_ev_set_direct()
  150.  */
  151. #define snd_seq_ev_schedule_real(ev, q, relative, rtime) \
  152.     ((ev)->flags &= ~(SND_SEQ_TIME_STAMP_MASK | SND_SEQ_TIME_MODE_MASK),\
  153.      (ev)->flags |= SND_SEQ_TIME_STAMP_REAL,\
  154.      (ev)->flags |= (relative) ? SND_SEQ_TIME_MODE_REL : SND_SEQ_TIME_MODE_ABS,\
  155.      (ev)->time.time = *(rtime),\
  156.      (ev)->queue = (q))
  157.  
  158. /**
  159.  * \brief set event priority
  160.  * \param ev event instance
  161.  * \param high_prior 1 for high priority mode
  162.  */
  163. #define snd_seq_ev_set_priority(ev, high_prior) \
  164.     ((ev)->flags &= ~SND_SEQ_PRIORITY_MASK,\
  165.      (ev)->flags |= (high_prior) ? SND_SEQ_PRIORITY_HIGH : SND_SEQ_PRIORITY_NORMAL)
  166.  
  167. /**
  168.  * \brief set fixed data
  169.  * \param ev event instance
  170.  *
  171.  * Sets the event length mode as fixed size.
  172.  *
  173.  * \sa snd_seq_ev_set_variable(), snd_seq_ev_set_varusr()
  174.  */
  175. #define snd_seq_ev_set_fixed(ev) \
  176.     ((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\
  177.      (ev)->flags |= SND_SEQ_EVENT_LENGTH_FIXED)
  178.  
  179. /**
  180.  * \brief set variable data
  181.  * \param ev event instance
  182.  * \param datalen length of the external data
  183.  * \param dataptr pointer of the external data
  184.  *
  185.  * Sets the event length mode as variable length and stores the data.
  186.  *
  187.  * \sa snd_seq_ev_set_fixed(), snd_seq_ev_set_varusr()
  188.  */
  189. #define snd_seq_ev_set_variable(ev, datalen, dataptr) \
  190.     ((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\
  191.      (ev)->flags |= SND_SEQ_EVENT_LENGTH_VARIABLE,\
  192.      (ev)->data.ext.len = (datalen),\
  193.      (ev)->data.ext.ptr = (dataptr))
  194.  
  195. /**
  196.  * \brief set varusr data
  197.  * \param ev event instance
  198.  * \param datalen length of the external data
  199.  * \param dataptr pointer of the external data
  200.  *
  201.  * Sets the event length mode as variable user-space data and stores the data.
  202.  *
  203.  * \sa snd_seq_ev_set_fixed(), snd_seq_ev_set_variable()
  204.  */
  205. #define snd_seq_ev_set_varusr(ev, datalen, dataptr) \
  206.     ((ev)->flags &= ~SND_SEQ_EVENT_LENGTH_MASK,\
  207.      (ev)->flags |= SND_SEQ_EVENT_LENGTH_VARUSR,\
  208.      (ev)->data.ext.len = (datalen),\
  209.      (ev)->data.ext.ptr = (dataptr))
  210.  
  211. /**
  212.  * \brief set queue controls
  213.  * \param ev event record
  214.  * \param typ event type
  215.  * \param q queue id
  216.  * \param val control value
  217.  */
  218. #define snd_seq_ev_set_queue_control(ev, typ, q, val) \
  219.     ((ev)->type = (typ),\
  220.      snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\
  221.      (ev)->data.queue.queue = (q),\
  222.      (ev)->data.queue.param.value = (val))
  223.  
  224. /**
  225.  * \brief set the start queue event
  226.  * \param ev event record
  227.  * \param q queue id to start
  228.  *
  229.  * \sa snd_seq_ev_set_queue_stop(), snd_seq_ev_set_queue_continue()
  230.  */
  231. #define snd_seq_ev_set_queue_start(ev, q) \
  232.     snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_START, q, 0)
  233.  
  234. /**
  235.  * \brief set the stop queue event
  236.  * \param ev event record
  237.  * \param q queue id to stop
  238.  *
  239.  * \sa snd_seq_ev_set_queue_start(), snd_seq_ev_set_queue_continue()
  240.  */
  241. #define snd_seq_ev_set_queue_stop(ev, q) \
  242.     snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_STOP, q, 0)
  243.  
  244. /**
  245.  * \brief set the stop queue event
  246.  * \param ev event record
  247.  * \param q queue id to continue
  248.  *
  249.  * \sa snd_seq_ev_set_queue_start(), snd_seq_ev_set_queue_stop()
  250.  */
  251. #define snd_seq_ev_set_queue_continue(ev, q) \
  252.     snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_CONTINUE, q, 0)
  253.  
  254. /**
  255.  * \brief set the stop queue event
  256.  * \param ev event record
  257.  * \param q queue id to change tempo
  258.  * \param val the new tempo value
  259.  */
  260. #define snd_seq_ev_set_queue_tempo(ev, q, val) \
  261.     snd_seq_ev_set_queue_control(ev, SND_SEQ_EVENT_TEMPO, q, val)
  262.  
  263. /**
  264.  * \brief set the real-time position of a queue
  265.  * \param ev event record
  266.  * \param q queue id to change tempo
  267.  * \param rtime the new real-time pointer
  268.  */
  269. #define snd_seq_ev_set_queue_pos_real(ev, q, rtime) \
  270.     ((ev)->type = SND_SEQ_EVENT_SETPOS_TIME,\
  271.      snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\
  272.      (ev)->data.queue.queue = (q),\
  273.      (ev)->data.queue.param.time.time = *(rtime))
  274.  
  275. /**
  276.  * \brief set the tick-time position of a queue
  277.  * \param ev event record
  278.  * \param q queue id to change tempo
  279.  * \param ttime the new tick-time
  280.  */
  281. #define snd_seq_ev_set_queue_pos_tick(ev, q, ttime) \
  282.     ((ev)->type = SND_SEQ_EVENT_SETPOS_TICK,\
  283.      snd_seq_ev_set_dest(ev, SND_SEQ_CLIENT_SYSTEM, SND_SEQ_PORT_SYSTEM_TIMER),\
  284.      (ev)->data.queue.queue = (q),\
  285.      (ev)->data.queue.param.time.tick = (ttime))
  286.  
  287. /* set and send a queue control event */
  288. int snd_seq_control_queue(snd_seq_t *seq, int q, int type, int value, snd_seq_event_t *ev);
  289.  
  290. /**
  291.  * \brief start the specified queue
  292.  * \param seq sequencer handle
  293.  * \param q queue id to start
  294.  * \param ev optional event record (see #snd_seq_control_queue)
  295.  */
  296. #define snd_seq_start_queue(seq, q, ev) \
  297.     snd_seq_control_queue(seq, q, SND_SEQ_EVENT_START, 0, ev)
  298.  
  299. /**
  300.  * \brief stop the specified queue
  301.  * \param seq sequencer handle
  302.  * \param q queue id to stop
  303.  * \param ev optional event record (see #snd_seq_control_queue)
  304.  */
  305. #define snd_seq_stop_queue(seq, q, ev) \
  306.     snd_seq_control_queue(seq, q, SND_SEQ_EVENT_STOP, 0, ev)
  307.  
  308. /**
  309.  * \brief continue the specified queue
  310.  * \param seq sequencer handle
  311.  * \param q queue id to continue
  312.  * \param ev optional event record (see #snd_seq_control_queue)
  313.  */
  314. #define snd_seq_continue_queue(seq, q, ev) \
  315.     snd_seq_control_queue(seq, q, SND_SEQ_EVENT_CONTINUE, 0, ev)
  316.  
  317. /**
  318.  * \brief change the tempo of the specified queue
  319.  * \param seq sequencer handle
  320.  * \param q queue id
  321.  * \param tempo the new tempo value
  322.  * \param ev optional event record (see #snd_seq_control_queue)
  323.  */
  324. #define snd_seq_change_queue_tempo(seq, q, tempo, ev) \
  325.     snd_seq_control_queue(seq, q, SND_SEQ_EVENT_TEMPO, tempo, ev)
  326.  
  327. /* create a port - simple version - return the port number */
  328. int snd_seq_create_simple_port(snd_seq_t *seq, const char *name,
  329.                    unsigned int caps, unsigned int type);
  330. /* delete the port */
  331. int snd_seq_delete_simple_port(snd_seq_t *seq, int port);
  332.  
  333. /* simple subscription between this port and another port
  334.    (w/o exclusive & time conversion)
  335.    */
  336. int snd_seq_connect_from(snd_seq_t *seq, int my_port, int src_client, int src_port);
  337. int snd_seq_connect_to(snd_seq_t *seq, int my_port, int dest_client, int dest_port);
  338. int snd_seq_disconnect_from(snd_seq_t *seq, int my_port, int src_client, int src_port);
  339. int snd_seq_disconnect_to(snd_seq_t *seq, int my_port, int dest_client, int dest_port);
  340.  
  341. /*
  342.  * set client information
  343.  */
  344. int snd_seq_set_client_name(snd_seq_t *seq, const char *name);
  345. int snd_seq_set_client_event_filter(snd_seq_t *seq, int event_type);
  346. int snd_seq_set_client_pool_output(snd_seq_t *seq, size_t size);
  347. int snd_seq_set_client_pool_output_room(snd_seq_t *seq, size_t size);
  348. int snd_seq_set_client_pool_input(snd_seq_t *seq, size_t size);
  349. /* sync output queue */
  350. int snd_seq_sync_output_queue(snd_seq_t *seq);
  351.  
  352. /*
  353.  * parse the given string and get the sequencer address
  354.  */
  355. int snd_seq_parse_address(snd_seq_t *seq, snd_seq_addr_t *addr, const char *str);
  356.  
  357. /*
  358.  * reset client input/output pool
  359.  */
  360. int snd_seq_reset_pool_output(snd_seq_t *seq);
  361. int snd_seq_reset_pool_input(snd_seq_t *seq);
  362.  
  363. /**
  364.  * \brief set note event
  365.  * \param ev event record
  366.  * \param ch channel number
  367.  * \param key note key
  368.  * \param vel velocity
  369.  * \param dur duration (in tick or msec)
  370.  */
  371. #define snd_seq_ev_set_note(ev, ch, key, vel, dur) \
  372.     ((ev)->type = SND_SEQ_EVENT_NOTE,\
  373.      snd_seq_ev_set_fixed(ev),\
  374.      (ev)->data.note.channel = (ch),\
  375.      (ev)->data.note.note = (key),\
  376.      (ev)->data.note.velocity = (vel),\
  377.      (ev)->data.note.duration = (dur))
  378.  
  379. /**
  380.  * \brief set note-on event
  381.  * \param ev event record
  382.  * \param ch channel number
  383.  * \param key note key
  384.  * \param vel velocity
  385.  */
  386. #define snd_seq_ev_set_noteon(ev, ch, key, vel) \
  387.     ((ev)->type = SND_SEQ_EVENT_NOTEON,\
  388.      snd_seq_ev_set_fixed(ev),\
  389.      (ev)->data.note.channel = (ch),\
  390.      (ev)->data.note.note = (key),\
  391.      (ev)->data.note.velocity = (vel))
  392.  
  393. /**
  394.  * \brief set note-off event
  395.  * \param ev event record
  396.  * \param ch channel number
  397.  * \param key note key
  398.  * \param vel velocity
  399.  */
  400. #define snd_seq_ev_set_noteoff(ev, ch, key, vel) \
  401.     ((ev)->type = SND_SEQ_EVENT_NOTEOFF,\
  402.      snd_seq_ev_set_fixed(ev),\
  403.      (ev)->data.note.channel = (ch),\
  404.      (ev)->data.note.note = (key),\
  405.      (ev)->data.note.velocity = (vel))
  406.  
  407. /**
  408.  * \brief set key-pressure event
  409.  * \param ev event record
  410.  * \param ch channel number
  411.  * \param key note key
  412.  * \param vel velocity
  413.  */
  414. #define snd_seq_ev_set_keypress(ev,ch,key,vel) \
  415.     ((ev)->type = SND_SEQ_EVENT_KEYPRESS,\
  416.      snd_seq_ev_set_fixed(ev),\
  417.      (ev)->data.note.channel = (ch),\
  418.      (ev)->data.note.note = (key),\
  419.      (ev)->data.note.velocity = (vel))
  420.  
  421. /**
  422.  * \brief set MIDI controller event
  423.  * \param ev event record
  424.  * \param ch channel number
  425.  * \param cc controller number
  426.  * \param val control value
  427.  */
  428. #define snd_seq_ev_set_controller(ev,ch,cc,val) \
  429.     ((ev)->type = SND_SEQ_EVENT_CONTROLLER,\
  430.      snd_seq_ev_set_fixed(ev),\
  431.      (ev)->data.control.channel = (ch),\
  432.      (ev)->data.control.param = (cc),\
  433.      (ev)->data.control.value = (val))
  434.  
  435. /**
  436.  * \brief set program change event
  437.  * \param ev event record
  438.  * \param ch channel number
  439.  * \param val program number
  440.  */
  441. #define snd_seq_ev_set_pgmchange(ev,ch,val) \
  442.     ((ev)->type = SND_SEQ_EVENT_PGMCHANGE,\
  443.      snd_seq_ev_set_fixed(ev),\
  444.      (ev)->data.control.channel = (ch),\
  445.      (ev)->data.control.value = (val))
  446.  
  447. /**
  448.  * \brief set pitch-bend event
  449.  * \param ev event record
  450.  * \param ch channel number
  451.  * \param val pitch bend; zero centered from -8192 to 8191
  452.  */
  453. #define snd_seq_ev_set_pitchbend(ev,ch,val) \
  454.     ((ev)->type = SND_SEQ_EVENT_PITCHBEND,\
  455.      snd_seq_ev_set_fixed(ev),\
  456.      (ev)->data.control.channel = (ch),\
  457.      (ev)->data.control.value = (val))
  458.  
  459. /**
  460.  * \brief set channel pressure event
  461.  * \param ev event record
  462.  * \param ch channel number
  463.  * \param val channel pressure value
  464.  */
  465. #define snd_seq_ev_set_chanpress(ev,ch,val) \
  466.     ((ev)->type = SND_SEQ_EVENT_CHANPRESS,\
  467.      snd_seq_ev_set_fixed(ev),\
  468.      (ev)->data.control.channel = (ch),\
  469.      (ev)->data.control.value = (val))
  470.  
  471. /**
  472.  * \brief set sysex event
  473.  * \param ev event record
  474.  * \param datalen length of sysex data
  475.  * \param dataptr sysex data pointer
  476.  *
  477.  * the sysex data must contain the start byte 0xf0 and the end byte 0xf7.
  478.  */
  479. #define snd_seq_ev_set_sysex(ev,datalen,dataptr) \
  480.     ((ev)->type = SND_SEQ_EVENT_SYSEX,\
  481.      snd_seq_ev_set_variable(ev, datalen, dataptr))
  482.  
  483. /** \} */
  484.  
  485. #ifdef __cplusplus
  486. }
  487. #endif
  488.  
  489. #endif /* __ALSA_SEQMID_H */
  490.  
  491.